# **INDEX**

| 1.System Process                                | 3  |
|-------------------------------------------------|----|
| 1.1 Process Overview                            | 3  |
| 1.2 Process of Chip                             | 4  |
| 2. Status Registers(BASE)                       | 5  |
| 2.1 System Status                               | 5  |
| 2.2 Transform Status                            | 8  |
| 3. Transform Input Registers                    | 10 |
| 3.1 Transform Control                           | 10 |
| 3.2 A USB Mode Parameter                        | 10 |
| 3-2 B TSIN Mode For A3                          | 11 |
| 4. MUX Registers                                | 11 |
| 4.1 Mux Related Settings                        | 11 |
| 5. PSI Register                                 |    |
| 5.1 Playload Buffer Register                    | 12 |
| 5.2 PSI Pure Mode                               | 12 |
| 5.3 Private PSI table                           | 13 |
| 6. Modulator Register                           | 14 |
| 6.1 Modulator Related Settings                  | 14 |
| 6.2 DVB-T Settings                              | 15 |
| 6.3 DVB-C (J83A) Settings                       | 16 |
| 6.4 ATSC (8VSB) Settings                        | 16 |
| 6.5 Clear QAM (J83.B) Settings                  | 16 |
| 6.6 DTMB Settings                               | 16 |
| 6.7 ISDB-T Settings                             | 17 |
| 6.8 J83.C Settings                              | 19 |
| 6.9 DVB-T2 Settings                             | 19 |
| 7. RF Mixer Registers                           | 21 |
| Appendix                                        | 24 |
| A. Register PSI/SI table by using PSI PURE mode | 24 |
| B. Insert PSI/SI table by using PSI PURF mode   | 26 |

| C. RF start flow (for VATek R2) | 27 |
|---------------------------------|----|
|                                 |    |

# **1.System Process**

# 1.1 Process Overview



# 1.2 Process of Chip



# 2. Status Registers(BASE)

The BASE registers are basic information register sets for VATek chips. Base register sets help developer to understand chip basic information and real-time status, which includes chip status, chip ID, supported functions and information lists and error code as well.

## 2.1 System Status

0x20 - HALREG\_SYS\_STATUS\_0: System Status Register

| Bit # | Туре | Value      | Name                      |
|-------|------|------------|---------------------------|
|       | R    | 0xFF000001 | SYS_STATUS_IDLE           |
|       | R    | 0xFF000002 | SYS_STATUS_RUN            |
|       | R    | 0xFF000080 | SYS_STATUS_ERRTAG         |
| 0-7 R | R    | 0xFF000085 | SYS_STATUS_LOADER FAIL    |
|       | R    | 0xFF000086 | SYS_STATUS_SERVICE_FAIL   |
|       | R    | 0xFF000088 | SYS_STATUS_EXCEPTION_FAIL |
|       | R    | 0xFF00008E | SYS_STATUS_BADSTATUS      |
|       | R    | 0xFF00008F | SYS_STATUS_UNKNOWN_FAIL   |
| 8-23  |      | Reserved   | Reserved                  |
| 24-31 | R    | 0xFF000000 | SYS_STATUS_TAG            |

### **Description**

This register use to read chip status, when reset chip and power up, chip status will be SYS\_STATUS\_IDLE, if the service is running, status will be SYS\_STATUS\_RUN,

**0x23 - HALREG SYS ERRCODE:** System Error Code

| Bit # | Туре | Value      | Name                 |
|-------|------|------------|----------------------|
|       | R    | 0x80000001 | SYS_ERRCODE_INIT     |
|       | R    | 0x80010001 | LOADER_ERRCODE_NOAPP |
| 0-31  | R    | 0x80010002 | LOADER_ERRCODE_CRC32 |
| 0-31  | R    | 0x80010003 | LOADER_ERRCODE_HW    |
|       | R    | 0x80020001 | SERVICE_INIT_FAIL    |
|       | R    | 0x80020002 | SERVICE_HW_FAIL      |

#### **Description**

This register use to show error code from chip, if firmware download fail in chip, the error code will happen.

0x24 - HALREG\_CHIP\_ID

| Bit # | Туре | Value      | Name               |
|-------|------|------------|--------------------|
|       | R    | 0x00010100 | HAL_CHIPID_A1      |
|       | R    | 0x00010300 | HAL_CHIPID_A3      |
|       | R    | 0x00020100 | HAL_CHIPID_B1      |
| 0-31  | R    | 0x00020200 | HAL_CHIPID_B2      |
|       | R    | 0x00020201 | HAL_CHIPID_B2_PLUS |
|       | R    | 0x00020300 | HAL_CHIPID_B3      |
|       | R    | 0x00020301 | HAL_CHIPID_B3_PLUS |

This register will show what chip is connecting,

0x25 - HALREG\_FW\_VER

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

## **Description**

This register shows firmware version, version number made by create date of firmware(.v2app) in hex.

0x26 - HALREG\_SERVICE\_MODE: Chip Service Mode

| Bit # | Туре | Value      | Name                  |
|-------|------|------------|-----------------------|
| 0~31  | R    | 0xFF000001 | SERVICE_TAG_RESCUE    |
|       | R    | 0xF8000001 | SERVICE_TAG_BROADCAST |
|       | R    | 0xF8000002 | SERVICE_TAG_TRANSFORM |

#### **Description**

This register shows chip services, we provide two services base on different chip series, and rescue mode is use to update firmware, you can you romtool to update firmware or use HAL regiseter to write v2img in chip.

0x27 - HALREG\_PERIPHERAL\_EN: Peripheral Chip ID

| Bit # | Туре | Value      | Name                  |
|-------|------|------------|-----------------------|
| 0.04  | R    | 0x000000FF | PERIPHERAL_RF_MASK    |
|       | R    | 0x00000002 | PERIPHERAL_FINTEKR2   |
| 0~31  | R    | 0x00FF0000 | PERIPHERAL_VIDEO_MASK |
|       | R    | 0x00010000 | PERIPHERAL_EP9555E    |

This register shows what peripheral device we connect with chip.

**0x28 - HALREG\_INPUT\_SUPPORT:** Supported Functions

| Bit # | Туре | Value      | Name                |
|-------|------|------------|---------------------|
| 0     | R    | 0x0000001  | INPUT_EN_TEST       |
| 1     | R    | 0x00000002 | INPUT_EN_USB        |
| 2     | R    | 0x0000004  | INPUT_EN_TS         |
| 3     | R    | 0x0000008  | INPUT_EN_ENC        |
| 4     | R    | 0x0000010  | VENC_EN_MPEG2       |
| 5     | R    | 0x00000020 | VENC_EN_H264        |
| 7     |      | Reserved   |                     |
| 8     | R    | 0x00000100 | VENC_EN_FULLHD      |
| 9 ~11 |      | Reserved   |                     |
| 12    | R    | 0x00001000 | AENC_EN_MP1_L2      |
| 13    | R    | 0x00002000 | AENC_EN_AAC_LC_ADTS |
| 14    | R    | 0x00004000 | AENC_EN_AC_3        |
| 15    | R    | 0x00008000 | AENC_EN_AAC_LC_LATM |
| 16    | R    | 0x00010000 | TSIN_EN_BYPASS      |
| 17    | R    | 0x00020000 | TSIN_EN_TSSMOOTH    |
| 18    | R    | 0x00040000 | TSIN_EN_TSREMUX     |
| 19    | R    | 0x00070000 | TSIN_EN_ALL         |
| 20    | R    | 0x00100000 | TEST_EN_HW          |
| 21    | R    | 0x00200000 | TEST_EN_REMUX       |
| 22    | R    | 0x00300000 | TEST_EN_ALL         |
| 23-31 |      | Reserved   | Reserved            |

## Description

This register shows many input we support, we support different input interfaced, and TS input interface has many process mode, BYPASS, TSSMOOTH, TSREMUX,

0x29 - HALREG\_OUTPUT\_SUPPORT: Supported Output Functions

| Bit # | Туре | Value      | Name          |
|-------|------|------------|---------------|
| 0     | R    | 0x00000001 | OUTPUT_EN_MOD |
| 2     | R    | 0x00000004 | OUTPUT_EN_TS  |
| 3     | R    | 0x00000008 | OUTPUT_EN_USB |
| 4-6   |      | Reserved   |               |

| 8     | R | 0x00000100 | MOD_EN_DVB_T     |
|-------|---|------------|------------------|
| 7     | R | 0x00000200 | MOD_EN_J83_A     |
| 9     | R | 0x00000400 | MOD_EN_ATSC      |
| 10    | R | 0x00000800 | MOD_EN_J83_B     |
| 11    | R | 0x00001000 | MOD_EN_DTMB      |
| 12    | R | 0x00002000 | MOD_EN_ISDB_T    |
| 13    | R | 0x00004000 | MOD_EN_J83_C     |
| 14    | R | 0x00008000 | MOD_EN_DVB_T2    |
| 15    | R | 0x00005F00 | MOD_EN_BASE      |
| 16    | R | 0x01000000 | DVB_T2_EN_FFT32K |
| 17-31 |   | Reserved   | Reserved         |

This register shows output we support, we have many modulators you can choose based on different country.

#### 2.2 Transform Status

**0x620 - HALREG\_BCINFO\_STREAM:** Show the setting value of HALREG\_BROADCAST\_STREAM.

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
|       | R    | 0x00000000 | STREAM_TESTMODE |
| 0.0   | R    | 0x00000001 | STREAM_USB      |
| 0~2   | R    | 0x00000002 | STREAM_TSIN     |
|       | R    | 0x00000003 | STREAM_ENCODER  |
| 3~31  |      | Reserved   |                 |

## **Description**

This register use to read what input interface using now,

# **0x621 - HALREG\_BCINFO\_OUTPUT:** Show the setting value of HALREG BROADCAST OUTPUT.

| Bit # | Туре | Value      | Name             |
|-------|------|------------|------------------|
| 0     | R    | 0x00000000 | OUTPUT_MODULATOR |
| 1~31  |      | Reserved   |                  |

## **Description**

This register use to read output mode, we provide modulator mode to be

output, you can choose different modulator type.

# 0x622 - HALREG\_BCINFO\_MODRATE

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

## **Description**

This register use to read real output bitrate of modulator, bitrate size base on different modulator type.

## **0x623 - HALREG\_BCINFO\_MUXRATE:** Show Bitrate of MUX.

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

## **Description**

This register use to read MUXER bitrate.

## 0x624 - HALREG\_BCINFO\_STATUS

| Bit # | Туре | Value      | Name                    |
|-------|------|------------|-------------------------|
|       | R    | 0x00000000 | BCSTATUS_IDLE           |
| 0~1   | R    | 0x0000001  | BCSTATUS_WAIT_SOURCE    |
| 0~1   | R    | 0x00000002 | BCSTATUS_BROADCAST      |
|       | R    | 0x0000003  | BCSTATUS_FINISH         |
| 2~31  |      | Reserved   |                         |
|       | R    | 0x80000000 | BCSTATUS_FAIL_UNKNOWN   |
|       | R    | 0x80000001 | BCSTATUS_FAIL_SOURCE    |
|       | R    | 0x80000002 | BCSTATUS_FAIL_TIMEOUT   |
|       | R    | 0x80000003 | BCSTATUS_FAIL_CODECDROP |
| 32    | R    | 0x80000004 | BCSTATUS_FAIL_BUFFER    |
|       | R    | 0x80000005 | BCSTATUS_FAIL_MUXER     |
|       | R    | 0x80000006 | BCSTATUS_FAIL_ENCODE    |
|       | R    | 0x80000007 | BCSTATUS_FAIL_MEDIA     |
|       | R    | 0x80000008 | BCSTATUS_FAIL_DEMUX     |

## **Description**

This register use to read broadcast status.

## **0x625 - HALREG\_BCINFO\_CURRATE:** Show real bitrate of MUX.

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

This register use to read current bitrate of MUXER

# 3. Transform Input Registers

Broadcaster registers are the main switches to activate / deactivate modulator, RF mixer. The operating status indicators are also in the register set.

## 3.1 Transform Control

**0x602 - HALREG\_TRANSFORM\_INPUT:** Transform input Select

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
|       | W    | 0x00000000 | STREAM_NULL |
| 0~1   | W    | 0x00000001 | STREAM_USB  |
|       | W    | 0x00000002 | STREAM_TSIN |

### 3.2 A USB Mode Parameter

## 0x640 - HALREG\_USB\_INPUT\_MODE: USB MODE Control

| Bit # | Туре | Value    | Name     |
|-------|------|----------|----------|
| 0     | W    |          |          |
| 1-31  |      | Reserved | Reserved |

#### **0x641 - HALREG\_USB\_STREAM\_FLAGS**: USB MODE FLAGS

| Bit # | Туре | Value    | Name     |
|-------|------|----------|----------|
| 0     | W    |          |          |
| 1-31  |      | Reserved | Reserved |

#### 0x642 - HALREG\_USB\_PCR\_MODE: PCR MODE IN USB MODE

| Bit # | Туре | Value    | Name     |
|-------|------|----------|----------|
| 0     | W    |          |          |
| 1-31  |      | Reserved | Reserved |

#### 0x643 - HALREG\_USB\_ADJUST\_TICK: USB MODE ADJUST TICK

### **SET**

| Bit # | Туре | Value    | Name     |
|-------|------|----------|----------|
| 0     | W    |          |          |
| 1-31  |      | Reserved | Reserved |

### 3-2 B TSIN Mode

# **0x640 - HALREG\_TSIN\_MODE:** TS mode select (Pure Modulator Only)

| Bit # | Туре | Value      | Name                    |
|-------|------|------------|-------------------------|
|       | W    | 0x00000001 | STREAM_MODE_SMOOTH      |
|       | W    | 0x00000002 | STREAM_MODE_REMUX       |
|       | W    | 0x00000003 | STREAM_MODE_PASSTHROUGH |
| 2-31  |      | Reserved   | Reserved                |

## **0x641 - HALREG\_TSIN\_FLAGS:** TS interface function flags

| Bit # | Туре | Value      | Name                  |
|-------|------|------------|-----------------------|
| 0     | W    | 0x0000001  | TS_PIN_SERIAL         |
| 1     | W    | 0x00000002 | TS_PIN_NEGATIVE_CLK   |
| 2     | W    | 0x0000004  | TS_PIN_NEGATIVE_VALID |
| 3     | W    | 0x00000008 | TS_PIN_NEGATIVE_SYNC  |
| 4-31  |      | Reserved   | Reserved              |

#### 0x642 - HALREG\_TSIN\_PCR\_MODE: TS PCR Mode

| Bit # | Туре | Value      | Name             |
|-------|------|------------|------------------|
| 0     | W    | 0x00000000 | PCR_MODE_DISABLE |
| 1     | W    | 0x0000001  | PCR_MODE_ADJUST  |
| 2     | W    | 0x00000002 | PCR_MODE_RETAG   |

# 4. MUX Registers

Regarding to the information of PSI/SI MUX insertion refers to psi insertion porting guide.

# 4.1 Mux Related Settings

#### **0x610 - HALREG\_MUX\_PCR\_PID:** Register for Writing PCR PID

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

## **0x611 - HALREG\_MUX\_PADDING\_PID:** Register for Writing Padding

PID

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

**0x612 - HALREG\_BITRATE:** Register for Writing Bitrate Limitation

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

## 0x2000 - HALREG\_MUXPSI\_MODE: Produce Mode of PSI

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0     | W    | 0x00000000 | MUX_PURE    |
| 3     | W    | 0x00000003 | MUX_DEFSPEC |
| 4~31  |      | Reversed   |             |

# 5. PSI Register

# 5.1 Playload Buffer Register

**0x2100 - HALRANGE\_PLAYLOAD\_START:** register of register PSI/SI table start tag, it's start at 0x2100.

| Bit# | Туре | Value | Name |
|------|------|-------|------|
| 0~31 | W    |       |      |

### 0x3000 - HALRANGE\_PLAYLOAD\_END: register of register PSI/SI

table end tag, it's end at 0x3000

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 5.2 PSI Pure Mode

Please follow appendix A

**0x00 - HALOF\_RAWPSI\_TAG:** start and end tag in PSI PURE mode, you need to use start tag when writing new PSI table, and use end tag after finishing table.

| Bit # | Туре | Value      | Name             |
|-------|------|------------|------------------|
| 0.04  | W    | 0xFF070600 | RAWPSI_EN_TAG    |
| 0~31  | W    | 0xFF0706FF | RAWPSI_EN_ENDTAG |

#### **0x01 - HALOF\_RAWPSI\_INTERVAL**: PSI Table Interval Time (ms)

| Bit# | Туре | Value | Name |
|------|------|-------|------|
| 0~31 | W    |       |      |

### 0x02 - HALOF\_RAWPSI\_PACKETS: PSI Table packet size

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 0x03 - HALOF\_RAWPSI\_DATA: write PSI table data continuously

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 5.3 Private PSI table

Please follow appendix B

Private PSI table is the way in PURE mode, it's only can be inserted table after chip start broadcast, but private PSI provide dynamically modify and insert table.

# **0x639 – HALREG\_PRIVATE\_START:** private stream playload start address

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

# **0x63A – HALREG\_PRIVATE\_END:** private stream playload end address

| Bit# | Туре | Value | Name |
|------|------|-------|------|
| 0~31 | W    |       |      |

#### **0x063B – HALREG\_PRIVATE\_CNTL:** private stream control

| Bit # | Туре | Value      | Name                |
|-------|------|------------|---------------------|
| 0     | W    | 0x80000000 | PRIVATE_EN_CONTINUE |
| 1     | W    | 0x00000001 | PRIVATE_EN_TIMES    |
| 2~31  | W    |            |                     |

#### Description

- PRIVATE\_EN\_CONTINUE: when write and read pointer are not equal, user can use this flag to send PSI table to chip.
- PRIVATE\_EN\_TIMES: set PRIVATE\_EN\_TIMES can insert table one time after broadcast start.

# **0x63C – HALREG\_PRIVATE\_WPTR:** Private stream write pointer (update by user)

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

**0x63D – HALREG\_PRIVATE\_RPTR:** private stream read pointer

### (update by hardware)

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

# 6. Modulator Register

# **6.1 Modulator Related Settings**

# **0x601 - HALREG\_TRANSFORM\_MODE:** Transform Mode Select

| Bit # | Туре | Value      | Name                |
|-------|------|------------|---------------------|
|       | W    | 0x00000005 | TRANSFORM_BROADCAST |

## 0x680 - HALREG\_MODULATOR: Modulation Standard Register

|       |      | _          | 5          |
|-------|------|------------|------------|
| Bit # | Туре | Value      | Name       |
|       | W    | 0x00000000 | MOD_DVB_T  |
|       | W    | 0x0000001  | MOD_J83A   |
|       | W    | 0x00000002 | MOD_ATSC   |
| 0.0   | W    | 0x00000003 | MOD_J83B   |
| 0~3   | W    | 0x0000004  | MOD_DTMB   |
|       | W    | 0x00000005 | MOD_ISDB_T |
|       | W    | 0x00000006 | MOD_J83C   |
|       | W    | 0x0000007  | MOD_DVB_T2 |
| 4~31  |      | Reserved   |            |

# **0x681 - HALREG\_MOD\_IFMODE:** Modulation Switch Register

| Bit # | Туре | Value      | Name             |
|-------|------|------------|------------------|
| 0~1   | W    | 0x00000001 | IFMODE_DISABLE   |
| 0~1   | W    | 0x00000003 | IFMODE_IQ_OFFSET |
| 2~31  |      | Reserved   |                  |

## **0x682 - HALREG\_MOD\_IFFREQ:** Offset Setting Register

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
|       | W    |       |      |

## **0x683 - HALREG\_MOD\_DACGAIN:** DAC Gain Setting Register

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
|       | W    |       |      |

# **0x684 - HALREG\_MOD\_BW\_SB:** Modulator Bandwidth or Symbol Rate Setting Register

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
|       | W    |       |      |

# **6.2 DVB-T Settings**

# 0x690 - HALREG\_DVB\_T\_CONSTELLATION: DVB-T Constellation

# Register

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0     | W    | 0x00000000 | DVB_T_QPSK  |
| 1     | W    | 0x00000002 | DVB_T_QAM16 |
| 2     | W    | 0x00000004 | DVB_T_QAM64 |
| 3~31  |      | Reserved   |             |

# 0x691 - HALREG\_DVB\_T\_FFT: DVB-T Carrier Mode Register

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0~1   | W    | 0x00000000 | DVB_T_FFT2K |
| 0~1   | W    | 0x00000001 | DVB_T_FFT8K |
| 2~31  |      | Reserved   |             |

## 0x692 - HALREG\_DVB\_T\_GUARDINTERVAL: DVB-T Guard Interval

# Register

| Bit # | Туре | Value      | Name          |
|-------|------|------------|---------------|
|       | W    | 0x00000000 | DVB_T_GI_1_32 |
| 0.1   | W    | 0x00000001 | DVB_T_GI_1_16 |
| 0~1   | W    | 0x00000002 | DVB_T_GI_1_8  |
|       | W    | 0x0000003  | DVB_T_GI_1_4  |
| 2~31  |      | Reserved   |               |

# 0x693 - HALREG\_DVB\_T\_CODERATE: DVB-T Code Rate Register

| Bit # | Туре | Value      | Name               |
|-------|------|------------|--------------------|
|       | W    | 0x00000000 | DVB_T_CODERATE_1_2 |
|       | W    | 0x00000001 | DVB_T_CODERATE_2_3 |
| 0~2   | W    | 0x00000002 | DVB_T_CODERATE_3_4 |
|       | W    | 0x00000003 | DVB_T_CODERATE_5_6 |
|       | W    | 0x00000004 | DVB_T_CODERATE_7_8 |
| 3~31  |      | Reserved   |                    |

# 6.3 DVB-C (J83A) Settings

# 0x690 - HALREG\_J83A\_CONSTELLATION: DVB-C (J83.A)

Constellation Register

| Bit # | Туре | Value      | Name         |
|-------|------|------------|--------------|
|       | W    | 0x00000000 | J83A_QAM16   |
|       | W    | 0x0000001  | J83A_QAM32   |
| 0~2   | W    | 0x00000002 | J83A_QAM64   |
|       | W    | 0x00000003 | J83A_QAM128  |
|       | W    | 0x0000004  | J83A_QAM_256 |
| 3~31  |      | Reserved   |              |

# 6.4 ATSC (8VSB) Settings

## 0x690 - HALREG\_ATSC\_ CONSTELLATION: ATSC (8VSB)

Constellation Register

| Bit # | Туре | Value      | Name      |
|-------|------|------------|-----------|
| 0     | W    | 0x00000000 | ATSC_8VSB |
| 1~31  |      | Reserved   |           |

# 6.5 Clear QAM (J83.B) Settings

# **0x690 - HALREG\_J83B\_CONSTELLATION:** Clear QAM(J83B)

Constellation Register

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0.1   | W    | 0x00000001 | J83B_QAM64  |
| 0~1   | W    | 0x00000003 | J83B_QAM128 |
| 2~31  |      | Reserved   |             |

# **6.6 DTMB Settings**

# **0x690 - HALREG\_DTMB\_CONSTELLATION:** DTMB Constellation

Register

| Bit # | Туре | Value      | Name       |
|-------|------|------------|------------|
| 0.2   | W    | 0x00000000 | DTMB_QPSK  |
| 0~2   | W    | 0x0000001  | DTMB_QAM16 |

|      | W | 0x00000002 | DTMB_QAM64 |
|------|---|------------|------------|
|      | W | 0x00000004 | DTMB_QAM32 |
| 3~31 |   | Reserved   |            |

## **0x691 - HALREG\_DTMB\_TIME\_INTERLEAVED:** DTMB Time

# Interleaved Register

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
|       | W    | 0x00000000 | DTMB_TI_DISABLE |
| 0.4   | W    | 0x00000001 | Reserved        |
| 0~1   | W    | 0x00000002 | DTMB_TI_240     |
|       | W    | 0x00000003 | DTMB_TI_720     |
| 2~31  |      | Reserved   |                 |

# 0x692 - HALREG\_DTMB\_CODERATE: DTMB Code Rate Register

| Bit # | Туре | Value      | Name              |
|-------|------|------------|-------------------|
|       | W    | 0x00000000 | DTMB_CODERATE_0_4 |
| 0~1   | W    | 0x0000001  | DTMB_CODERATE_0_6 |
|       | W    | 0x00000002 | DTMB_CODERATE_0_8 |
| 2~31  |      | Reserved   |                   |

# 0x693 - HALREG\_DTMB\_CARRIERMODE: DTMB Carrier Register

| Bit # | Туре | Value      | Name              |
|-------|------|------------|-------------------|
| 0     | W    | 0x00000000 | DTMB_CARRIER_3780 |
|       | W    | 0x0000001  | DTMB_CARRIER_1    |
| 1~31  |      | Reserved   |                   |

# 0x694 - HALREG\_DTMB\_SYNCFRAME: DTMB Sync Frame Mode

## Register

| Bit # | Туре | Value      | Name          |
|-------|------|------------|---------------|
|       | W    | 0x00000000 | DTMB_SYNC_420 |
| 0~1   | W    | 0x00000001 | DTMB_SYNC_945 |
|       | W    | 0x00000002 | DTMB_SYNC_595 |
| 2~31  |      | Reserved   |               |

# 6.7 ISDB-T Settings

## **0x690 - HALREG\_ISDB\_T\_CONSTELLATION: ISDB-T Constellation**

## Register

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
|-------|------|-------|------|

|      | W | 0x00000000 | ISDB_T_DQPSK |
|------|---|------------|--------------|
| 0.4  | W | 0x0000001  | ISDB_T_QPSK  |
| 0~1  | W | 0x00000002 | ISDB_T_QAM16 |
|      | W | 0x00000003 | ISDB_T_QAM64 |
| 2~31 |   | Reserved   |              |

# **0x691 - HALREG\_ISDB\_T\_FFT:** ISDB-T Carrier Mode Register

| Bit # | Туре | Value      | Name         |
|-------|------|------------|--------------|
|       | W    | 0x00000000 | ISDB_T_FFT2K |
| 0~1   | W    | 0x00000001 | ISDB_T_FFT8K |
|       | W    | 0x00000002 | ISDB_T_FFT4K |
| 2~31  |      | Reserved   |              |

# **0x692 - HALREG\_ISDB\_T\_GUARDINTERVAL:** ISDB-T Guard Interval

# Register

| Bit # | Туре | Value      | Name           |
|-------|------|------------|----------------|
|       | W    | 0x00000000 | ISDB_T_GI_1_32 |
| 0.1   | W    | 0x00000001 | ISDB_T_GI_1_16 |
| 0~1   | W    | 0x00000002 | ISDB_T_GI_1_8  |
|       | W    | 0x00000003 | ISDB_T_GI_1_4  |
| 2~31  |      | Reserved   |                |

# **0x693 - HALREG\_ISDB\_T\_CODERATE:** ISDB-T Code Rate Register

| Bit # | Туре | Value      | Name                |
|-------|------|------------|---------------------|
|       | W    | 0x00000000 | ISDB_T_CODERATE_1_2 |
|       | W    | 0x00000001 | ISDB_T_CODERATE_2_3 |
| 0~2   | W    | 0x00000002 | ISDB_T_CODERATE_3_4 |
|       | W    | 0x00000003 | ISDB_T_CODERATE_5_6 |
|       | W    | 0x00000004 | ISDB_T_CODERATE_7_8 |
| 3~31  |      | Reserved   |                     |

# 0x694 - HALREG\_ISDB\_T\_TIME\_INTERLEAVED: ISDB-T Time

# Interleave Register

| Bit # | Туре | Value      | Name              |
|-------|------|------------|-------------------|
|       | W    | 0x00000000 | ISDB_T_TI_DISABLE |
| 0~1   | W    | 0x00000001 | ISDB_T_TI_MODE1   |
| 0~1   | W    | 0x00000002 | ISDB_T_TI_MODE2   |
|       | W    | 0x00000003 | ISDB_T_TI_MODE3   |
| 2~31  |      | Reserved   |                   |

# 6.8 J83.C Settings

# **0x690 - HALREG\_J83C\_CONSTELLATION:** J83.C Constellation

#### Register

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0     | W    | Reserved   |             |
| 1     | W    | 0x00000002 | J83C_QAM64  |
| 2     | W    | 0x00000004 | J83C_QAM256 |
| 3~31  |      | Reserved   |             |

# 6.9 DVB-T2 Settings

# 0x691 - HALREG\_DVB\_T2\_FLAGS: DVB-T2 Control Register

| Bit # | Туре | Value      | Name                        |
|-------|------|------------|-----------------------------|
| 0     | W    | 0x00000001 | T2EN_EXTEND_CARRIER_MODE    |
| 1     | W    | 0x00000002 | T2EN_CONSTELLATION_ROTATION |
| 2     | W    | 0x00000004 | T2EN_INPUT_TS_HEM           |
| 3     | W    | 0x00000008 | T2EN_DELETE_NULL_PACKET     |
| 4     | W    | 0x00000010 | T2EN_VBR_CODING             |
| 5     | W    | 0x00000020 | T2EN_TIME_INTERVAL          |
| 6~31  |      | Reserved   |                             |

## 0x692 - HALREG\_DVB\_T2\_ISSY: DVB-T2 ISSY Register

| _ |       |      |            |                 |
|---|-------|------|------------|-----------------|
|   | Bit # | Туре | Value      | Name            |
|   |       | W    | 0x00000000 | T2_ISSY_DISABLE |
|   | 0~1   | W    | 0x00000002 | T2_ISSY_SHORT   |
|   |       | W    | 0x00000003 | T2_ISSY_LONG    |
|   | 2~31  |      | Reserved   |                 |

# 0x693 - HALREG\_DVB\_T2\_NIT: DVB-T2 NIT Register

| Bit # | Туре | Value      | Name           |
|-------|------|------------|----------------|
| 0     | W    | 0x00000000 | T2_NTI_DISABLE |
| 1~31  |      | Reserved   |                |

## 0x694 - HALREG\_DVB\_T2\_L1\_CONSTELLATION: DVB-T2 L1

Constellation Register

| D:4 # | Type  | Value | Name |
|-------|-------|-------|------|
| Bit # | ı ype | value | Name |

|      |   | W | 0x00000000 | T2_L1_BPSK  |
|------|---|---|------------|-------------|
| 0.0  |   | W | 0x0000001  | T2_L1_QPSK  |
| 0~2  |   | W | 0x00000002 | T2_L1_QAM16 |
|      |   | W | 0x00000003 | T2_L1_QAM64 |
| 3~31 | I |   | Reserved   |             |

# 0x695 - HALREG\_DVB\_T2\_PLP\_CONSTELLATION: DVB-T2 PLP

Constellation Register

| Bit # | Туре | Value      | Name          |
|-------|------|------------|---------------|
|       | W    | 0x00000000 | T2_PLP_QPSK   |
| 0.0   | W    | 0x0000001  | T2_PLP_QAM16  |
| 0~2   | W    | 0x00000002 | T2_PLP_QAM64  |
|       | W    | 0x00000003 | T2_PLP_QAM256 |
| 3~31  |      | Reserved   |               |

# **0x696 - HALREG\_DVB\_T2\_FFT:** DVB-T2 Carrier Mode Register

| Bit # | Туре | Value      | Name       |
|-------|------|------------|------------|
|       | W    | 0x00000000 | T2_FFT_1K  |
|       | W    | 0x00000001 | T2_FFT_2K  |
| 0.0   | W    | 0x00000002 | T2_FFT_4K  |
| 0~2   | W    | 0x00000003 | T2_FFT_8K  |
|       | W    | 0x00000004 | T2_FFT_16K |
|       | W    | 0x00000005 | T2_FFT_32K |
| 3~31  |      | Reserved   |            |

# 0x697 - HALREG\_DVB\_T2\_CODERATE: DVB-T2 Code Rate Register

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
|       | W    | 0x00000000 | T2_CODERATE_1_2 |
|       | W    | 0x0000001  | T2_CODERATE_3_5 |
|       | W    | 0x00000002 | T2_CODERATE_2_3 |
| 0.0   | W    | 0x0000003  | T2_CODERATE_3_4 |
| 0~2   | W    | 0x0000004  | T2_CODERATE_4_5 |
|       | W    | 0x00000005 | T2_CODERATE_5_6 |
|       | W    | 0x00000006 | T2_CODERATE_1_3 |
|       | W    | 0x00000007 | T2_CODERATE_2_5 |
| 3~31  |      | Reserved   |                 |

# 0x698 - HALREG\_DVB\_T2\_GUARDINTERVAL: DVB-T2 Guard Interval

Register

| Bit # | Туре | Value      | Name         |
|-------|------|------------|--------------|
|       | W    | 0x00000000 | T2_GI_1_32   |
|       | W    | 0x0000001  | T2_GI_1_16   |
|       | W    | 0x00000002 | T2_GI_1_8    |
| 0~2   | W    | 0x0000003  | T2_GI_1_4    |
|       | W    | 0x0000004  | T2_GI_1_128  |
|       | W    | 0x0000005  | T2_GI_19_128 |
|       | W    | 0x00000006 | T2_GI_19_256 |
| 3~31  |      | Reserved   |              |

# **0x699 - HALREG\_DVB\_T2\_PILOTPATTERN:** DVB-T2 Pilot Pattern Register

| Bit # | Туре | Value      | Name    |
|-------|------|------------|---------|
|       | W    | 0x00000000 | T2_PP_1 |
|       | W    | 0x0000001  | T2_PP_2 |
|       | W    | 0x00000002 | T2_PP_3 |
| 0.0   | W    | 0x0000003  | T2_PP_4 |
| 0~2   | W    | 0x0000004  | T2_PP_5 |
|       | W    | 0x0000005  | T2_PP_6 |
|       | W    | 0x00000006 | T2_PP_7 |
|       | W    | 0x0000007  | T2_PP_8 |
| 3~31  |      | Reserved   |         |

# **0x69A - HALREG\_DVB\_T2\_FECTYPE:** DVB-T2 FEC Frame Length Register

| Bit # | Туре | Value      | Name         |
|-------|------|------------|--------------|
| 0     | W    | 0x00000000 | T2_FEC_16200 |
| 0     | W    | 0x0000001  | T2_FEC_64800 |
| 1~31  |      | Reserved   |              |

# 7. Transform Relate Register

# 7.1 General Register

**0x600 - HALREG\_TRANSFORM\_CNTL:** Transform Control

| Bit # | Туре | Value      | Name                     |  |
|-------|------|------------|--------------------------|--|
| 0     | W/R  | 0x0000001  | ASE_CMD_START            |  |
| 1     | W/R  | 0x00000002 | BASE_CMD_STOP            |  |
| 2     | W/R  | 0x00000004 | BASE_CMD_TEST_START_SINE |  |
| 3     | W/R  | 0x00000008 | BASE_CMD_TEST_START      |  |

| 4-7   |     | Reserved   | Reserved         |  |
|-------|-----|------------|------------------|--|
| 8     | W/R | 0x00000100 | BC_REBOOT        |  |
| 9     | W/R | 0x00000200 | BC_REBOOT_RESCUE |  |
| 10-11 |     | Reserved   | Reserved         |  |
| 12    | W/R | 0x00001000 | BC_RFMIXER_START |  |
| 13    | W/R | 0x00002000 | BC_RFMIXER_STOP  |  |
| 14-30 |     | Reserved   | Reserved         |  |

<sup>\*</sup>type W/R register: The register will be cleared after commend executed.

- BASE CMD START: service start command.
- BASE CMD STOP: service stop command.
- BASE\_CMD\_TEST\_START\_SINE: use sine wave starting.
- BASE\_CMD\_TEST\_START: test mode start.
- BASE\_CMD\_REBOOT: software reset command using with BASE\_CMD\_REBOOT\_RESCURE, if user want to reset chip by software reset, can using this command without chip fail.
- BASE\_CMD\_REBOOT\_RESCURE: software reset command using with BASE\_CMD\_REBOOT, if user want to reset chip by software reset, can using this command without chip fail.
- RFMIXER CMD START: RF start command, control by VATek chip.
- RFMIXER\_CMD\_STOP: RF start command, control by VATek chip.

# 7.2 RF Mixer Registers

#### 0x1200 - HALREG\_RF\_COM\_STATUS: R2 RF MIXER Status Register

| Bit # | Туре | Value      | Name             |
|-------|------|------------|------------------|
| 0-1   | R    | 0x0000001  | RF_STATUS_IDLE   |
|       | R    | 0x00000002 | RF_STATUS_ACTIVE |
| 2-30  |      | Reserved   | Reserved         |
| 31    | R    | 0x80000000 | RF_STATUS_FAIL   |

## 0x1202 - HALREG\_RF\_COM\_FREQ: R2 RF MIXER Frequency

#### Register

| Bit # | Туре | Value | Name                              |  |
|-------|------|-------|-----------------------------------|--|
| 0-31  | W/R  |       | Write desired Frequency (Mhz).    |  |
| 0-31  |      |       | - Frequency minimum step is 1 MHz |  |

| 1 |                                       |
|---|---------------------------------------|
|   | - Frequency Range from 50Mhz ~ 950MHz |

# **Appendix**

# A. Register PSI/SI table by using PSI PURE mode

Register table during 0x2100 to 0x3000 , refer 5.2 ∘



| PLAYLOAD RANGE                                          |                                                         |                                                         |                  |  |  |  |
|---------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------|------------------|--|--|--|
| PSI TABLE                                               | PSI TABLE                                               | PSI TABLE                                               | 9                |  |  |  |
| RAWPSI_EN_TAG PSI Interval PSI Packet Number PSI Packet | RAWPSI_EN_TAG PSI Interval PSI Packet Number PSI Packet | RAWPSI_EN_TAG PSI Interval PSI Packet Number PSI Packet | RAWPSI_EN_ENDTA0 |  |  |  |

| Syntax                                                                   | Bits |
|--------------------------------------------------------------------------|------|
| PSITABLE_REGISTER() {                                                    |      |
| for (i=0; i <table_number; i++)="" td="" {<=""><td></td></table_number;> |      |
| RAWPSI_EN_TAG                                                            | 32   |
| HALOF_RAWPSI_INTERVAL                                                    | 32   |
| HALOF_RAWPSI_PACKETS                                                     | 32   |
| HALOF_RAWPSI_DATA                                                        | 32*N |
| }                                                                        |      |
| RAWPSI_EN_ENDTAG                                                         | 32   |
| }                                                                        |      |
|                                                                          |      |

Table\_Number: number of register PSI/SI table , 16 is maximum 。

RAWPSI\_EN\_TAG: start tag when registering PSI/SI table •

HALOF\_RAWPSI\_INTERVAL: interval of transport table •

HALOF\_RAWPSI\_PACKETS: packet number of PSI/SI table , each packet

max is 188 Bytes •

HALOF\_RAWPSI\_DATA: data of register PSI/SI -

RAWPSI\_EN\_ENDTAG: end tag of register PSI/SI -

# B. Insert PSI/SI table by using PSI PURE mode

Insert table during 0x2100 to 0x3000, refer 5.3



# C. RF start flow (for VATek R2)

